博客
关于我
oc工程中oc、swift混编代码打包成静态framework踩坑笔记
阅读量:407 次
发布时间:2019-03-05

本文共 1114 字,大约阅读时间需要 3 分钟。

两天时间探索,期间不知遇到了多少问题,各种google和Stack Overflow,甚至都求助了群友的力量。期间也想过放弃,还好有一颗不甘心。终于成功了!

开心,哈哈,希望有缘人遇到同样问题的话,下面的一些记录可以帮助到你。

成功后,静态库里Swift和OC代码可以被OC工程中OC和Swift类使用。

一、编译库时,选debug可以成功,但是release不成功

原因:上面文章中忘记说要把库设置为static的步骤了。

正确方式:在静态库的buildsetting搜索mach,选择Static Library。

二、stroyboard放到bundle中无法被成功加载

需要在绑定了控制器的storyboard的CustomClass处,指定Module为包含对应类的静态库,同时不勾选Inherit Module From Target。

三、图片放到bundle中格式不对

设置Build Setting中的COMBINE_HIDPI_IMAGES为NO,否则Bundle中的图片就是tiff格式了。

四、Swift代码无法被外界OC代码访问

通过相关群里与群友交流,发现是需要在被访问的Swift类前加@objc public。如果需要继承Swift的类,可能需要加@objc open。

五、Swift代码的协议方法无法回调

Xcode很傻的提示在协议方法前加@nonobjc,很坑!后来不甘心把同样代码以非静态库形式集成到工程里,发现居然仍然有协议方法不回调的问题。于是尝试把@nonobjc改为了public,居然就可以了!于是又使用git相关命令reset到静态库的某个tag版本。发现这么改之后整个流程就通了!

六、多target引用相同和不同第三方库问题

可以通过cocopods解决此问题。例如:

1 # Uncomment the next line to define a global platform for your project2 platform :ios, '11.3'3 abstract_target 'Shows' do4   #用_frameworks! 如果需要使用Swift或动态框架5   use_frameworks!6     # Pods for ZWEasyWalkMap7     pod 'Realm', '~> 3.13.1'8   end9   target 'ZWEasyWalkMap-SHXJD' do10     pod 'Realm', '~> 3.13.1'11   end12 end

😔,踩坑了两天,一把辛酸泪啊!略作记录,以表欣慰。

转载地址:http://mcmzz.baihongyu.com/

你可能感兴趣的文章
phoenix无法连接hbase shell创建表失败_报错_PleaseHoldException: Master is initializing---记录020_大数据工作笔记0180
查看>>
Phoenix简介_安装部署_以及连接使用---大数据之Hbase工作笔记0035
查看>>
phoenix连接hbase报错Can not resolve hadoop120, please check your network_记录026---大数据工作笔记0187
查看>>
Photoshop工作笔记001---Photoshop常用快捷键总结
查看>>
Reids配置文件redis.conf中文详解
查看>>
PHP
查看>>
Regular Expression Notes
查看>>
PHP $FILES error码对应错误信息
查看>>
PHP $_FILES函数详解
查看>>
php & 和 & (主要是url 问题)
查看>>
php -- 魔术方法 之 判断属性是否存在或为空:__isset()
查看>>
php -- 魔术方法 之 获取属性:__get()
查看>>
php -树-二叉树的实现
查看>>
PHP -算法-二路归并
查看>>
php 2条不一样 的json数据 怎么放在一个json里面_如果你是PHP开发者,请务必了解一下Composer...
查看>>
php 360 不记住密码,JavaScript_多种方法实现360浏览器下禁止自动填写用户名密码,目前开发一个项目遇到一个很 - phpStudy...
查看>>
regExp的match、exec、test区别
查看>>
php aes sha1解密,PHP AES加密/解密
查看>>
php csv 导出
查看>>
PHP imap 远程命令执行漏洞复现(CVE-2018-19518)
查看>>